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Description 

The present Invention relates the vector acces- 
sing of memories, for example in a memory device 
used in a vector processor, and more particularly 
concerns the constant stride accessing of the 
memory device. 

In recent high speed vector processors, a main 
memory device is divided Into a plurality of mem- 
ory banks, enabling parallel access thereto In order 
to decrease the total access time to many data 
items, and to provide a fail-soft structure for the 
memory device, that is. to minimize destruction 
should a failure occur. 

Data stored In a memory device is accessible 
by indicating In a program address numbers of 
memory cells where desired data items are stored. 
In order to make access to a plurality of data items 
which are stored in memory cells having contig- 
uous address numbers, it is not necessary to in- 
dicate all of the addresses (address numbers) in a 
program. The computer is provided with an ad- 
dress generator which outputs successively the 
necessary addresses when a starting address and 
an end address are given, or a starting address 
and a length of an address chain are given. So, 
data is automatically read out or stored In succes- 
sion. A group of addresses in which data Is stored 
in such a manner is called in the art a vector 
address, and a method of making access to such 
data is called a vector access. 

When the memory device has a plurality of 
memory cells arranged In several banks, each of 
the memory cells stores a data element or item 
and each of the memory locations or cells Is num- 
bered. This number Is called an address number or 
address Index. The numbering is interleaved 
through all the banks, in a manner as illustrated in 
upper ha(f of Fig. t. Namely, the memory cells are 
numbered from the first row of the first bank, then 
to the first row of the second bank and then the 
first row of the third bank, and so on. When the first 
row of the final bank has been numbered, the 
second rows of the banks are numbered in succes- 
sion. In Fig. 1 only four banks are shown, and the 
numbering, therefore, is four-way interleaved. In 
general a memory device is provided with many 
banks, depending on the size of memory afforded 
by the device. So, if the memory device is pro- 
vided with n banks, the addresses are n-way inter- 
leaved, and n numbers are used to identify the 
individual banks, each number being called a bank 
number or bank Index. 

An example of a vector access is illustrated in 
Fig. 2, When a first address (4 in this example) and 
an end address (27) are given, an address gener- 
ator outputs all of the address indices indicated by 
hatching in Fig. 2 in succession, in order of ad- 



dress number. The data stored in these memory 
cells is accessed. The hatched area Is a vector 
address. Such an address may be called more 
particularly a contiguous vector address or a se- 

5 quential address, and a procedure for accessing 
such an address Is called a contiguous vector 
access or a sequential access. 

However, in practice in data processing, it often 
occurs that it is necessary to make access to data 

10 items which are stored in memory cells which have 
indices skipping or separated by a constant num- 
ber. An example is shown in Fig. 3. in this exam- 
pie, the number of banks is 16, so address num- 
bers are 1 8-way interleaved. In the Figure, the 

75 desired addresses are 0, 3, 3, 9, C, F ... (These 
numbers being expressed as hexa-decimal numer- 
als). They are stored at addresses between which 
two addresses are skipped, or at addresses sepa- 
rated by two addresses. The difference between 

20 the address numbers of neighbouring desired ad- 
dresses Is called the distance, or stride, in the 
above example, therefore, the distance is three. A 
sequence of addresses of this kind is called in the 
art a distanced vector address or a constant stride 

25 address, and a procedure for accessing such an 
address (address sequence) is called a distanced 
vector access or a constant stride access. 

A procedure for accessing a memory which 
includes indicating all addresses one by one In a 

so program is called sometimes a scalar access. 

A requirement for distanced vector access of- 
ten occurs in processing of vectors or In matrix 
processing. Of course there are many cases other 
than matrix processing which call for distanced 

35 vector access. A process for distanced vector ac- 
cess will be explained briefly, using matrix pro- 
cessing as an example. Consider a matrix of m 
rows and n columns such as:- 

40 

■11 a 12 ai3 * 1n 
a 21 a 22 a 23 a 2n 



6 m1 a ro2 a m3 «ran 

the data elements a™ are usually arranged In 
accordance with the sequence of their column In- 

so dex n or their row index m, and they are stored in 
respective addresses of a memory device In order 
of element index mn. If It Is desired to make 
access to data elements In order of column index 
n, that Is In accordance with the succession an, 

w ai 2 , ai3 .... contiguous vector access as mentioned 
above Is convenient However, if it is desired to 
make access to data elements in order of row 
index m, that is in accordance with an , aai , aai 
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distanced vector access Is needed. 

A memory device Is provided with a bank 
controller which controls access to each of the 
banks or allots priority to accesses. Whilst one 
bank is being accessed from one processor, the $ 
bank controller prohibits further access to this 
bank, and when the access to this one bank is 
complete, the bank controller enables another pro- 
cessor to access this one bank. Such bank control- 
lers have been provided in respect of each bank, 10 
but as the number of banks Increased, the cost of 
the hardware Increased. Therefore, for modern pro- 
cessors, various proposals for bank control have 
been made with a view to reducing the number of 
bank controllers and to providing a more economi- is 
cal memory device. 

One example of a proposal for bank control 
involves allotting a time slot to each bank during 
which time slot access to the bank concerned is 
allowed, and the time slot is shifted from one bank 20 
to another in sequence. For example, as shown in 
the lower half of Fig. 1, access to bank 1 is allowed 
only in time period Tt, during this time period 
access to other banks is forbidden, in a next time 
period T 2( bank 2 is enabled, and other banks are £5 
forbidden. In the following time period T3, only 
bank 3 is enabled. In similar manner, all of the 
banks are enabled sequentially one by one. This Is 
called sequential bank control. 

Another proposal Involves grouping of banks, so 
an access controller being provided for each bank 
group. For example, 12 banks may be grouped into 
four groups each having three banks. A bank con- 
troller checks the three banks in respect of which it 
Is provided, and if one of the banks in the group is ss 
responding to an access, it forbids further access 
to the group. The description below will refer to 
sequential bank control! but H will be apparent for 
one skilled fn the art that the discussion can be 
applied to any such bank control method as men- 40 
tioned above. 

An example of how data stored in the ad- 
dresses of a distance vector address have pre- 
viously been accessed will be described. Fig. 3 is 
an address chart illustrating a sixteen-way Inter- 46 
leave and distance of three. When banks are en- 
abled one by one to respond to an access within a 
predetermined time slot, In this case data In ad- 
dress 0 In bank 0 Is first accessed during a first 
time slot. so 

In the description hereinafter, both a memory 
cell having an address number and the data stored 
In the cell will be referred to simply as an address, 
unless it is specifically indicated or apparent that 
this is not intended. So, "access to an address" $s 
means access to data stored in a memory cell 
having an appropriate address number. 
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The next address to be accessed is 3 In bank 
3, but processor is forbidden to access bank 3 
during the next two time slots (after access to 
address 0). Only In the fourth time slot Is address 3 
in bank 3 accessed. Similarly, when one address 
has been accessed, the following two time slots are 
skipped without accessing any bank. In the above 
example, therefore, only one address is accessed 
for every three time slots, in the data sequence 0, 
3, 8. 9, C. and F. Then the addresses 12, 15, 18, 
1B ... are accessed in succession. This procedure 
is repeated until ail of the distanced vector ad- 
dresses have been accessed. 

As can be understood from the above explana- 
tion, access to each of the data elements In a 
vector address is accomplished during only one of 
several time slots covering one distance or stride 
of the address. So, total access time to a distanced 
vector address is long. In the example of Fig. 3, 48 
time slots are necessary to access 16 addresses. 
Generally, the throughput of a memory device de- 
creases approximately to 1/D when it is accessed 
In accordance with distanced vector address hav- 
ing a distance D, compared to the throughput when 
It Is accessed In accordance with a contiguous 
vector address having the same number of data 
elements. 

The reason for this inconvenience can be at- 
tributed to the address generator. In previously 
proposed address generators! addresses are gen- 
erated in order of address indices. Namely, in the 
case of Fig. 3, the addresses are generated in the 
order 0, 3, 6 ... 2A and 2D. Therefore, a processor 
has to wait several time slots before it can access 
a next address. An exemplary circuit configuration 
of a previously proposed address generator Is 
shown in Fig. 4. In this Figure, a start address is 
set in a start address register (SADR) 51 and a 
distance is set in a distance register (DIST) 52. In 
the case of Rg. 4, the value of the distance (e.g. 3) 
is added to the start address (e.g. 0) by an adder 
(ADD) 53, producing a new address number 3. This 
number Is registered In an address register (ADR) 
54 via the register 51. Then, the distance 3 is again 
added to the address number 3. producing a new 
address number 6, and so on. In such a manner, 
new addresses are generated one after another in 
address index order. Accordingly, the addresses 0, 

3. 6. 9. G, F. 12, 15, , are obtained in sequence. 

These generated addresses are stored In the ad- 
dress register 54 for a while, and accessing to 
memory 55 is carried out. 

It will be understood that constant stride ac- 
cess to a memory using such an address generator 
takes a very long time. This represents a significant 
disadvantage for processing speed In a high speed 
vector processor. 
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According to the present invention there is 
provided apparatus operable to perform a constant 
stride vector access to a constant stride vector 
address of a memory device, the vector address 
having a starting address and a distance or stride, s 
the memory device having a plurality of memory 
banks numbered with respective bank indices, and 
individual addresses of the memory device being 
numbered with respective address indices inter- 
leaved through the memory banks, the apparatus 10 
Including an address generator, operable to gen- 
erate successive address indices of the constant 
stride vector address, comprising: 

generating means for generating a sequence of 
first numbers of which the first one Is zero and is 
which differ from each another by a value com- 
puted in accordance to an equation 

c x 0 ■ 1 (mod B) 

20 

where B and D are positive integers coprime to 
each other, B being the number of banks of the 
memory device and D being the said distance or 
stride of the vector address, or B being the number 
of banks and D the stride after division by the 25 
greatest common factor of the number of banks 
and the stride, and c being a positive integer called 
a delta Index; 

correction means operable such that said ad- 
dress indices are generated on the basis of said jo 
first numbers referred to modulus B x D; and 

adding means coupled to said correction 
means and to a starting address index register so 
that the generated address indices are based on 
the starting address index. ss 

According to the present Invention there is also 
provided a method of performing a constant stride 
vector access to a constant stride vector address 
of a memory device, the vector address having a 
starting address and a distance or stride, the mem- *a 
ory device having a plurality of memory banks 
numbered with respective bank indices, and in- 
dividual addresses of the memory device being 
numbered with respective address indices inter- 
leaved through the memory banks, the method 45 
comprising generating successive address indices 
of the constant stride vector address, by> 

(a) generating a sequence of first numbers of 
which the first one is zero and which differ from 
each another by a value computed In accor- so 
dance to an equation 

cxD a 1 (mod B) 

where B and D are positive integers coprime to ss 
each other, B being the number of banks of the 
memory device and D being the said distance 
or stride of the vector address, or B being the 



number of banks and D the stride after division 
be the greatest common factor of the number of 
banks and the stride, and c being a positive 
integer called a delta index, 
<b) effecting correction such that said address 
Indices are generated on the basis of said first 
numbers referred to modulus BxD; and 
(c) adding a value based on the starting address 
Index so that the generated address Indices are 
based on the starting address index. 
In accordance with embodiments of the present 

invention, higher speed access to constant stride 

addresses can be provided. 

An embodiment of the present invention can 

realize this higher speed access using equipment 

with ordinary hardware. 

Employment of embodiments of the present 

invention can provide for improved throughput of a 

memory device under vector access. 

In accordance with an embodiment of the 

present Invention addresses are generated in the 

order of memory banks which are enabled for 

access. 

An embodiment of the present Invention pro- 
vides an address generator with which addresses 
are generated not in order of address Index but in 
order of bank index to be accessed. For instance, 
addresses for accomplishing the vector access of 
the example of Rg. 3 are generated in the se- 
quence 0 ( 21, 12, 3, 24, 15, 6 .... as illustrated in 
Rg. 5. In this way memories are accessed without 
skipping banks. So. there Is no waiting time in the 
memory device for the skipping of banks. There- 
fore, total access time for D distant vector ad- 
dresses is reduced to approximately 1/D of the 
access time previously required. 

In short, embodiments of the invention provide 
for the output of the address numbers of a distant 
vector address, arranged not in order of the ad- 
dress Index but in order of the bank index. An 
address generator is provided which outputs suc- 
cessively such address numbers. 

The advantages of the present Invention are, 
therefore, of value particularly in relation to. so 
called super computers, which have high process- 
ing performances for carrying out scientific and 
technical calculations. 

Reference is made, by way of example, to the 
accompanying drawings In whlch:- 
Ftg. 1 

is a schematic diagram illustrating how address 
numbers are Interleaved in memory banks, and 
how these banks are accessed in accordance 
with a time slot sequence. 

is an address chart illustrating how a contiguous 
vector address is stored in a memory device 
having plurality of memory banks, 
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Fig. 3 

is an address chart Illustrating a distanced vec- 
tor address stored in memory banks, 
Fig. 4 

Is a schematic block diagram of a previously 
proposed address generator, 
Fig. 5 

is an example of vector address which is ar- 
ranged in the order of bank indices, 
Fig. 6 

is a schematic block diagram Illustrating part of 
an address generator for accomplishing a dis- 
tanced vector access in accordance with an 
embodiment of the present Invention, 
Fig. 7 

is an address chart illustrating an example of a 
distanced vector address of considerable length, 
Fig. 8 

Is a schematic block diagram illustrating an ex- 
ample of an address correction circuit employed 
in an address generator in accordance with an 
embodiment of the present invention, 
Figs. 9 and 10 

are schematic block diagrams of parts of further 
address generators for accomplishing distanced 
vector accesses in accordance with embodi- 
ments of the present Invention, 
Fig. 11 

is a schematic block diagram Illustrating a modi- 
fication of the address correction circuit shown 
in Rg. 8, to be applied to the generator of Fig. 
10, 

Fig. 12 

is a schematic block diagram illustrating an ex- 
ample of a divider circuit which may be used in 
an address generator in accordance with an 
embodiment of the present invention, 
Fig. 13 

is a flow chart relating to the divider circuit of 
Rg. 12. 
Fig. 14 

is a schematic block diagram illustrating the 
overall configuration of an address generator In 
accordance with an embodiment of the present 
invention. 
Fig. 15 

is a flow chart relating to the address generator 
of Rg. 14, 
Fig. 16 

is an example of a DISTANCE - DELTA chart. 

and 

Rg. 17 

Is an address chart of a distanced vector ad- 
dress corresponding to a case in which values 
of B and D are not coprime to each other. 
Throughout the Figures, the same reference 
numerals designate and identify the same or simi- 
lar parts. 



For understanding the present Invention It is 
useful to note the following mathematical consider- 
ations. What is known as the Euclidian Algorithm, 
or the method of mutual division, Indicates that if 
6 integers B and D are coprime to each other, there 
exist positive Integers a and c satisfying the follow- 
ing equation 

a.B + c.D = 1 (mod B) 

10 

The right side of the equation means a number 
which is an integral multiple of B plus 1, or, in 
other words, if this number Is divided by B it leaves 
a remainder of 1. The number B Is known as the 
75 modulo or modulus. Therefore, the equation means 
there Is a combination of numbers a.B and c.D 
which has a remainder of 1 If It Is divided by B. 

Since a,B is a multiple of B, equation (1) can 
be simplified to 

20 

c,D = 1 (mod B) 

The number c Is called the delta index hereafter. 
An embodiment of the present invention makes 

26 use of this relationship. Namely, rf B is an address 
interleave number, that is, if B is the number of 
banks, and D the distance or stride between ad- 
dresses of a constant stride vector address, a 
number c (positive integer) can be obtained which 

so makes a multiple of D by c larger by 1 than a 
multiple of the interleave number B. This means 
that, starting from any address in any bank, If the 
address is increased by a number which is c times 
the distance D f the resulting address number is 

as one which belongs to a bank next Indexed to the 
initial bank. 

The significance of the above relationship will 
become more apparent from the following example. 
Let the Interleave number B be 128, and the dis- 
40 tance D be 7. This means the example relates to a 
large memory device having 128 banks. The fol- 
lowing relationship can be obtained 

55x7 = 3x128 + 1 

46 

Therefore, C = 55. This means that if addresses in 
a (any) bank are skipped 55 times with a stride of 
7, the new address is positioned in (relates to) a 
bank which is next to the initial bank; 

so This may be further explained as follows. If the 
elements (individual addresses) of a distanced vec- 
tor address are designated by Vfl), where I is a 
vector index (1= 1, 2, 3, 4, 5.... etc.), and the 
starting address of the vector address is Indicated 

6S by s, then the address numbers of the elements 
are given by 

s + (i-1)D. 
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For instance, if s ■ 1, and the stride D = 7 as 
in the above example, the address numbers are 1, 

8, 15, (which addresses are found in banks 1, 

8, 15, etc)- 

tn previous proposals, the elements are acces- 
sed In this order, i.e. address number order, for 
example bound by a maximum address number B 
x D. In other words they are accessed in order of 
vector indexes i = l, 2, 3, 4, .... etc., bound by a 
maximum index B. 

In an embodiment of the present invention, 
however, the elements in this example are acces- 
sed in a different order of vector Indexes, cor- 
responding to a series as follows 

i = 1 + p x c (mod B) 

where p = 0, 1, 2, 3, 4, 5, .... etc.. 

That Is, In terms of the above example, the 
elements are accessed in order of vector indexes 
1, 56, 111, .... etc.. 

This corresponds to accessing individual ad- 
dresses in the order of address numbers 

s + (p x c x D) (mod B x D) 

where p = 0, 1, 2, 3, 4, 5, .... etc*. 

in terms of the above example this corre- 
sponds to the order 1, 388, 771, .... etc.. 

This means that the accesses are in bank 

index order SB, SB + 1, SB + 2, SB + 3, etc., 

where SB is the bank index of the bank holding the 
starting address. 

So, if the bank Index of a bank which includes 
an address corresponding to vector index 1 Is writ- 
ten as FB(i), the starting address of the vector 
address is 1, and the bank Index of the starting 
bank which Includes the starting address is written 
as SB, the relation between the indices of above 
example becomes 



FB<75> = SB + 6 
FB<2) = SB + 7 



FBC1) 

FB(56) 

FBC111 ) 

FB(38) 

FBC93) 

FB<20) 



SB 

SB * 1 
SB + 2 
SB + 3 
SB + 4 
SB + 5 



10 



15 



20 



50 



35 



40 



60 



55 



FBC19) = SB + 126 
FBC74) = SB ♦ 127 

Therefore, if the vector indices (or address indices 
corresponding to the vector indices) 1, 56, 111, 38, 
93 ... are generated successively, a quick access 
to the vector address is possible, because there Is 
no need to wait for banks to be skipped after 
accessing one address before accessing a next 
address. 

Next, operation of an address generator in ac- 
cordance with an embodiment of the present inven- 
tion, to output address Indices In order of bank 
index, will be explained. The explanation will be 
based, for better understanding, on a case in which 
address numbers as shown in Fig. 5 are output. 

In this case, the number of banks (the inter- 
leave number) 8 Is taken to be 16 and the distance 
D is taken to be 3. So. one solution of the equation 
(2)lsc = 11,thatis 

11 x3 o 2x 16 + 1 

This means that if the address number is increased 
by 11 x 3 (= 33), it becomes equal to the sum of 
an integral multiple of the interleave number end 
unity. Therefore, the bank index number of the 
bank which includes that address Is Increased by 
1. 

Fig. 6 is a block diagram illustrating in outline 
an address generator In accordance with an em- 
bodiment of the present invention, which generator 
operates according to the above described logic. 
Trie value of c (= 11 In the example of Fig. 5) is 
set In a delta Index register (DELTA) 1. and the 
distance D (- 3) is set in a distance register 
(DIST) 4. These values are multiplied together by a 
multiplier (MULT) 5 and sent to a first index regis- 
ter (INDR) 2. There is provided a second index 
register (INDR) 2' which is set to zero at a starting 
time. The values in the first and second index 
registers 2, 2' are added to each other by an adder 
(ADD) 3, the output of which is fed back to the 
second index register 2', and the value In the 
second register 2* is replaced by the number out- 
put from the adder 3. Accordingly, the output of the 
adder 3 becomes successively 0, 33. 86. 99, ... 
When a starting address number is added to these 
numbers, they correspond to required address 
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numbers. 

The outputs of the adder 3 correspond to the 
required addresses, but they are not exactly the 
required addresses. As can be seen from Figs. 3 
and 5, the outputs should b© replaced by numbers 
having a modulus of B x D. This correction is 
achieved in an index correction circuit (CORR) 10 
in the block diagram of Fig. 6. The function and 
configuration of the index correction circuit 10 will 
be described below. 

Fig. 7 is a chart of addresses in a memory 
device having 16 banks (B=16). An access Is 
required which involves a skip or distance of 5 
addresses. Therefore, the distance D is 5. The 
delta index c is calculated from equation (2) as 13. 
In the chart, the required addresses are Identified 
by shading. Since c x D = 65, the adder 3 of Fig. 
6 outputs successively 0, 65, 130, 195 .... Whh 
these outputs, addresses such as 50, 35, 20 etc. 
would not be obtained. Therefore, the' outputs of 
the adder 3 must be corrected to turn back to the 
initial index when the output Indices exceed a 
maximum index of (B x D), that is 80 in this 
example. In effect, the outputs of adder 3 should 
wrap round from the maximum index (60) to the 
Initial index (e.g. 0). That means the indices (the 
outputs of adder 3) should be replaced by R(mod 
y) where y is the maximum index. That is 80 in this 
example. 

If required addresses have a maximum ad- 
dress of 200 for example, the output address in- 
dices should be replaced by R(mod (BxCx D)), 
that is in this example, R(mod 1040), and address 
indices exceeding 200 should be neglected. 

The address correction circuit 10 in FJg, 6 
which performs the above functions Is Illustrated In 
Fig. 8. The correction circuit contains two dividers 
11 and 12. The dividers each perform following 
operation. 

x * y = Q and R (3) 

where Q Is the quotient and R is the remainder. 
This relation can be written as 

x - y x Q + R (4) 

or using the modulo, it may be replaced by 

x = R (mod y) (5) 

The configuration of a divider will be explained 
later. 

The output of the adder 3 (address Indices) in 
Fig. 6 are successively fed to a terminal ADR-IN 
and fed to respective x terminals of the dividers 11 
and 12 in Fig. 8. The values of c, B and D are 
applied respective terminals DELTA, BANK and 



DIST, These notations, written in capital letters, will 
be used also to designate the values applied to the 
respective terminals hereinafter. In the following 
description, the case of Rg. 7 will be referred to as 
5 an example. Referring to Fig. 7. it will be apparent 
that the first group of Indices which are denoted as 
G-1 in the chart are obtained if ADR-JN is replaced 
by R(mod 80), This means in general that the ADR- 
IN (x) should be replaced by 

10 

R(mod y) where y = B x D (8) 

This operation is carried out by the first divider 
11 in Fig. 8. In Fig. 8, the y terminal of the divider 

is 11 is supplied from a multiplier 13 which provides 
B x D (16 x 5 ■ 80). Accordingly, the divider 11 
outputs successively 0, 65, 50, 35, 20 ... 

Inspecting Fig. 7, It will be understood that the 
second group of Indices which are denoted as G-2 

20 can be obtained respectively by adding 80 ( = B x 
D) to the corresponding indices of the first group. 
The third group of the indices denoted as G-3 can 
be obtained by adding 160 (=80 x 2) to the 
corresponding first group indices. It will be appar- 

25 ent that succeeding indices can ' be obtained in a 
similar manner, adding a number B x D x Q to 
each of the indices of the group one. 

Such operation is effected by the second di- 
vider 12, third and fourth multipliers 15, 16 and an 

qo adder 17. In Rg. 8. the divider 12 performs an 
operation 

x/y - ADR-IN/(c x B x D) = Q and R 

$5 The second multiplier 15 provides B x D x c 
(=16 x 5 x 13 ■ 1040). This number Is the value 
of x (= ADR-1N) corresponding to an index 80 in 
Fig. 7. Therefore, for all Indices in the first group 
G-1, the value of x is smaller than 1040, in the 

40 example of Fig. 7. Therefore, the second divider 12 
outputs 0 as the quotient Q, For the second group 
6-2 of the indices.the value of x becomes equal to 
or larger than 1040 and less than 2080 ( = 2 x 
1040). So the second divider outputs 1 for the 

«s quotient Q. Similarly for the third group G-3 of 
Indices it will become apparent from careful In- 
spection of Fig. 7, that x values are between 2080 
and 3120. So Q becomes 2. 

In Fig. a the third multiplier 16 multiplies the 

60 value of B x D (= 80) by Q (=0, 1, 2 ...). This is 
added by the adder 17 to the first group indices 
outputted from the R terminal of the first divider 11. 
Thus the address numbers for any size (length) of 
data are obtained, A process for stopping index 

55 generation above a maximum index (200 for exam- 
ple) will be discussed later with respect to total 
configuration of an address generator as shown in 
Fig. 14, 
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Referring back to Fig. 6. the starting address is 
set in a start address register (SAOR) 8, and added 
to the output of the address correction circuit 
(CORR) 10 by a second adder 7. . The output of the 
second adder 7 is registered in an address register 
(ADR) 8 as the requested address, and the data 
stored in the RAM 9 Is accessed by this new 
address. 

Address generation as described above can be 
modified in various ways. Fig. 9 illustrates another 
address generator in accordance with an embodi- 
ment of the present invention, corresponding to a 
modification of Fig. 6. Compared with Rg. 8, the 
generator of Fig. 9 differs In the dlsposltloning of 
multiplier 5 and adder 3 (and in that the generator 
of Fig. 9 has only one index register (INDEX) 2). 
Explanation will be given again, referring to the 
example of Fig. 5. in F]g. 9, the same reference 
numerals designate parts similar to those In Rg. 6. 
The values of c (=11) and distance D (=3) are set 
respectively in a delta register 1 and a distance 
register 4. To the value of c an Index sent from the 
Index register 2 Is added In an adder 3, and the 
result Is fed back to the index register 2 to replace 
the former Index therein. The index register 2 is set 
to 0 as a starting condition. So, the output of the 
adder 3 becomes successively 0, 11, 22, 33, 44, 
55 

The distance value D (=3) set in the distance 
register 4, and the outputs of the adder 3 are 
multiplied together by the multiplier 5, producing 
successive outputs of 0, 33, 68, 99, 132 .... These 
values are corrected (replaced by a modulus form) 
by the address correction circuits 10, as described 
above. So, the output of the address correction 
circuit 10 becomes, successively, 0, 33, 18, 3, 36 
.... To these vaJues, the start address (=0 In this 
example) is added by the adder 7 to provide the 
required addresses, 0, 33, 18. 3, 38 .... When these 
values are expressed In hexa-declmal numerals, 
they become 0. 21, 12, 3, 24 ... as shown In Fig. 5. 

Rg- 10 shows a modification of the address 
generator of Fig. 9, In accordance with another 
embodiment of the present Invention. Comparing 
this system with that of Fig. 9, the address correc- 
tion circuit 10' is positioned between the adder 3 
and the multiplier 5. The same reference numerals 
designate Hems similar to those in Fig. 9. in the 
generator of Fig. 10, the outputs of the adder 3 are 
corrected, that is replaced by the modulo from. It 
will by understood easily by the person skilled in 
the art that the arrangement of Fig. 10 provides the 
same addresses to those provided by Rg. 9. The 
outputs of the adder 7 are registered in an address 
register 8, and the memory 9 is accessed in accor- 
dance with address numbers given from the ad- 
dress register a 



In the generator of Rg. 10, the correction cir- 
cuit 10' should be modified as shown In Rg. 11. 
Compared with the correction circuit of Rg. 8, 
multipliers 13 and 15 are eliminated and replaced 
6 by a single multiplier id. Other circuit elements are 
the same to those of Rg. a Operations will be 
easily understood by analogy with the arrange- 
ments described above. 

So, in a manner described above, a vector 

io address is accessed in order of memory bank 
index and, therefore, no waiting time is necessary 
for the processor, because the necessary address- 
es are generated successively In order of bank 
Index. Thus, a quick access to a distanced vector 

75 address can be attained. 

An index correction circuit 10 or 10' described 
above comprises a divider circuit which calculates 
the equations (3), or (5). Any circuit which performs 
such operation may by used in place of the circuits 

so described. An example is shown in Rg. 12. In an x 
register 18 and y register 19 are respectively set 
the values of x and y. As can be seen In Rg. 12, 
the divider circuit is fundamentally composed of a 
subtracter (SUBT) 20, a comparator (COMP) 21 

25 and a counter circuit 22. The values of x and y are 
compared in the comparator 21. If x is smaller than 
y, then x is equal to R» and if x is larger than or 
equal to y, then y is subtracted from x by the 
subtracter 20, and the output of the subtracter 20 is 

jo fed back to the x register 18, and replaces the 
former x value. The counter 22 is set first to zero, 
and the count Increased by 1, by a plus one 
generator 23, each time the comparator 21 detects 
that x is larger than or equal to y. In such manner, 

qs the process Is repeated until the value in the x 
register becomes smaller than y. The value remain- 
ing In the x register 18 is equal to the remainder R, 
and the value In the counter gives the quotient Q. A 
flow chart for this divider circuit is given in Rg. 13. 

ao The overall circuit of an address generator in 
accordance with an embodiment of the invention is 
shown in Rg. 14. The left side half of the Rgures is 
equivalent to the circuit of Rg. 10. The reference 
numerals, therefore, correspond to those of Rg. 1 0. 

45 Request Address Register (RADR) 8 corresponds 
to address register (ADR) 8 in Rg. 10, and Indetx 
Adder (IADD) 3 corresponds to adder (ADD) 3 in 
Rg. 10. A minor modification will be noticed at the 
input side of the multiplier 5. Namely, In Rg. 10, 

60 the Input of the multiplier 5 Is connected to the 
output side of the correction circuit 10', but In Fig. 
14, the Input of the multiplier 5 fs supplied from the 
Index register (INDEX or simply IND) 2. It will be 
understood by those skilled in the art that this 

65 difference is not a difference of substance, it re- 
lates only to the timing techniques used. In the 
disclosure which follows explanation will be given 
with respect to the flow of data, and discussion of 
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timing will be omitted for the sake of simplicity. 

to the right half side of the Figure are provided 
a length register (LENGTH) 24 and a request coun- 
ter (REQ CNTR or simply REQ) 25. To these 
registers is set the length of the vector address, 
that is a number corresponding to the difference of 
the indices between the end address and the start- 
ing address of the vector address. Referring to the 
example of Fig. 7, if the required data items are 
those having addresses from 0 to 200, the number 
41 Is set in LENGTH. If the starting address is 10 
and the end address is 200, then the length should 
by 39. At each cycle of the index adder (IADO) 3, 
the INO (index, from index register 2) is compared 
with the LENGTH by a comparator 20. If IND Is 
smaller than or equal to the LENGTH, then the 
comparator 26 outputs 1, and the value 1 Is stored 
in a request valid register (RVAL or simply VAL) 
29. If IND is larger than LENGTH, then the com- 
parator 26 outputs 0, and the value in VAL Is set to 
0. When VAL is 1 f a decrementor 27 outputs -1 
and this value Is fed back to the request counter 
25. in such a manner, the value REQ in the request 
counter Is reduced by 1 each time the index gener- 
ator 2 outputs a new index. As the output of the 
INDEX increases, and when it exceeds the 
LENGTH, VAL becomes 0. When VAL is 0 and 
REQ becomes 0 a zero detector (ZERO DETECT) 
28 detects this, and sends a signal to the memory 
control unit (not shown) to stop the process of 
address generation. The memory control unit is a 
common unit provided for all of the memory de- 
vices for controlling overall operation of the mem- 
ory device. 

A flow chart illustrating the above process Is 
shown in Fig. 15. in a step one. which is denoted 
by an encircled number 1, the start address SADR, 
distance DlST, delta DELTA and length LENGTH 
are set IND is set to "0" for example and the 
request counter 25 Is also set. Initial values for 
relevant registers are thus set In step two which Is 
denoted by an encircled number 2, an addition 
process Is performed In [ADD 3. In a step three 
denoted by an encircled number 3 a decision is 
made either to continue the process or to end the 
process, and enable reception of a next request 
from a processor (not shown). 

From the above explanation, it will be under- 
stood that the delta index c can be obtained by 
calculation as a solution of equation (2). The cal- 
culation is neither difficult nor troublesome. How- 
ever, it is practical to use a (pre-prepared) °chart w 
indicating the values of c for various distance val- 
ues D. An example of such a DISTANCE - DELTA 
chart is shown in Fig. 16. Since the bank number B 
is pre-determlned for each memory device, one 
chart is sufficient for each memory device. If such 
a chart Is prepared for a memory device to be 



used, It Is possible to obtain the value of c when 
the distance D Is given In a programming step. 

Fig. 16 is an example of a DISTANCE - DELTA 
chart for a computer having 128 banks, that is B = 
5 128. In the chart, the first column in each row entry 
indicates the distance number D. The value D is 
factorized by 2 n , and shown in the second column 
of the entry. For example, at the row entry f or D = 
24 it is shown that 24 is equal to 3x 8 ( = 2 3 ). The 

io asterisk " means multiplication. In the third column 
in each row entry the delta Index c Is shown. For 
example, in row D = 34, a c value of 49 Is given. 
Values of c can be obtained very quickly from such 
a chart So. programming becomes very easy. In 

75 the fourth column of each row entry, in brackets 
the value of D x c is shown as an aid to consider- 
ation. This Is a number to be added to an address 
index in order to obtain a next address index which 
is included in the next larger (bank) indexed bank. 

so Further, and practically, a DISTANCE - DELTA 
chart may be memorized in a memory device. So, 
in programming it is not necessary to go over the 
DISTANCE - DELTA chart, when bank number B 
and distance D is given in the program, a subrou- 
tine of the program can look over the chart to find 
the delta index c and then generate requested 
address numbers in a manner as described above. 

• In the foregoing description, it has been as- 
sumed that the values B and D are coprime to 

30 each other. However, embodiments of the present 
invention can easily be applied In cases in which B 
and D are not coprime to each other, h becomes 
apparent by testing for both cases, that if the value 
of D is modified, constant stride access can be 

re accomplished with great benefits in terms of ac- 
cess throughput. 

This will be explained with respect to a case in 
which interleave B - 16 end distance D = 6, for 
example, Relevant addresses are illustrated in Fig. 

40 17, identified by shading. As can be seen in the 
Figure, the desired addresses are positioned in 
banks whose indexes differ by two. In this case, 
distance 6 can be expressed as 3 x 2. Since 3 is 
coprime with 8, delta is found to be 3, because 

45 

3x3 = 1x8 + 1 =» 1(mod8) 
so, 

60 6x3 = 16 + 2 = 2(mod 16) 

This means that if the address index is increased 
by 6 x 3 * 18. the bank number is increased by 2. 
Therefore, If the values B = 16, c = 3 and D ■ 6 
56 are provided, the address generator described 
above will output the addresses identified by shad- 
ing as shown in Fig. 17. In this example, constant 
stride access throughput is improved by approxl- 
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mately a factor of three In comparison with a case 
in which a contiguous type vector access is made. 
This is apparent because within a time period dur- 
ing which a previously proposed contiguous access 
method accesses address 0 and is waiting for 
access to address 6. the embodiment of the 
present Invention accesses three addresses 0. 18 
and 36. 

h will be understood that, generally when B 
and D are not coprime to each other, there Is a 
greatest common measure (factor) (3 for B and D. 
So, B and D can be expressed respectively as 

B = G x B' 

and 

D = G x 0' 

using B' and D\ equation (2) can be modified as 
CxD' = t(modB') (2 1 ) 

Thus, it will be apparent that an address gener- 
ator operating in accordance with the rule of equa- 
tion (2), where B and D are coprime to each other, 
is applicable without any modification to a case in 
which B and D are not coprime to each other, If the 
modified vaJues B' and D' are used. 

The above process can be generalized using a 
DISTANCE - DELTA chart as follows, referring to 
Fig. 16. When distance is given, find the value of 
delta (c) in the row corresponding to the distance. 
For example, if D = 50, then ft will be found that c 
= 41. 

As a special case, It will be noticed from the 
chart that for some values of distance, for example 
2, 4, 8, 18 etc., the' value of delta becomes 1. In 
such cases, it will be understood that the ad- 
dresses are all, in effect, vertically aligned in sev- 
eral columns. In such special cases, embodiments 
of the present invention do not offer particular 
advantages but, on the other hand the total access 
time even for such "worst cases" is never longer 
than that required in previous proposals. It should 
be further noticed, that it is common sense in 
terms of advanced programming technology to 
avoid designing a program using a distance value 
of 2 ft in order to arrange the necessary addresses 
in a column. So, in normal cases, embodiments of 
the present invention provide a significant advan- 
tage over previous proposals. 

Further, It will be apparent by checking output 
indices for practical cases, that the distanced vec- 
tor access as provided by embodiments of the 
present Invention is applicable to memory devices 
wherein memory banks are group controlled, with- 
out any device modification. 



In the above description, circuit elements re- 
ferred to, multipliers, registers, counters etc. are all 
conventional and are available on the market as IC 
packages. Therefore, rt is not necessary to use any 
6 special circuit elements to Implement circuitry in 
accordance with an embodiment of the invention. 
Nonetheless throughput of a memory device can 
be improved very much compared to previous pro- 
posals. 

10 Embodiments of the present invention provide 
a method and means for generating addresses for 
a distanced vector address or a constant stride 
vector address. The address generator generates 
requested address indices following an equation 

is 

cD = 1(mod B) 

where B is the bank number of the memory device, 
D is the distance or stride of the vector address 
20 and c is a positive integer called the delta index. 
The requested addresses are successively gen- 
erated in order of bank addresses of a memory 
device which stores the vector address. So, waiting 
time which has been necessary for skipping over 
ss banks from one address to a next address In 
previously proposed distanced vector access meth- 
ods has been eliminated. The throughput of the 
memory device Is Improved. 

Embodiments of the present invention provide 
so apparatus or method for performing a constant 
stride vector access to a constant stride vector 
address, having a starting address index and hav- 
ing a stride D, of a memory device having a 
plurality of memory banks, B in number, desig- 
ns nated by respective bank indices and with individ- 
ual address locations designated by address in- 
dices interleaved across the memory banks, 
wherein 

(a) when B and D are coprime, a number c is 
40 determined which satisfies :- 

c x D = 1 (mod B) 

where c is a positive integer called a delta 
45 index, or 

(b) when B and D are not coprime, the number 
c is determined which satisfies :- 

cxD' = 1(modB') 

50 

where 
B = GxB' 
66 and 

D = 6xD', 
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Q being the greatest common factor of B and D. 
Using c, a series of address indexes are gen- 
erated derived from numbers of the series 

n x c x O 

where n is 0, 1, 2, 3 ..-etc., and the starting address 
added thereto, so that the successively generated 
address indexes relate to successively accessible 
banks. 

The numbers of the series n x c x D are not 
used directly but are corrected, i.e. they are sub- 
ject to or referred to a modulus, so that the cor- 
rected numbers wrap around from a maximum 
value B x D to 0 (zero). In this way a "basic" series 
of address indexes (from 0 to B x D) is provided. 
Address indexes above B x O are provided by 
adding multiples of B x D to the basic series of 
address indexes. 

Correction as mentioned above may be effec- 
ted as follows:- 
either 

(i) c x D is determined, and subjected to cu- 
mulative addition to provide numbers 1 x (c x 
D), 2 x (c x D),..etc, or 

(ii) c is cumulatively added, to provide numbers 
1 x c, 2 x c ... etc., or 

(jil) □ js cumulatively added, to provided num- 
bers 1 x D, 2 x D ... etc.. 
Then either. 

(A) In case (I) the numbers provided, or in case 
(II) or (IH) the numbers provided multiplied by D 
(In case II) and c (in case iii) are subject to 
correction of a form 

I = R (mod B x D) 

where R refers to corrected numbers and I to 
uncorrected numbers, to provide the basic se- 
ries of address indexes, or 

(B) in case (ii) or case (iii) the numbers provided 
are subject to correction of a form 

I - R (mod B), 

then the corrected numbers R multiplied by D 
(case li) or c (case 111), to provide the basic 
series of address Indexes. 

Claims 

1. Apparatus operable to perform a constant 
stride vector access to a constant stride vector 
address of a memory device, the vector ad- 
dress having a starting address and a distance 
or stride, the memory device having a plurality 
of memory banks numbered with respective 
bank indices, and individual addresses of the 



memory device being numbered with respec- 
tive address indices interleaved through the 
memory banks, the apparatus including an ad- 
dress generator, operable to generate succes- 

5 sive address indices of the constant stride 
vector address, comprising: 

generating means (1, 2, 2\ 3, 4, 5) for 
generating a sequence of first numbers of 
which the first one is 2ero and which differ 

10 from each another by a value computed in 
accordance to an equation 

cx D = 1 (mod B) 

75 where B and D are positive integers coprime to 
each other, B being the number of banks of 
the memory device and D being the said dis- 
tance or stride of the vector address, or B 
being the number of banks and D the stride 
20 after division by the greatest common factor of 
the number of banks and the stride, and c 
being a positive Integer called a delta Index; 

correction means (10) operable such that 
said address indices are generated on the ba- 
ss sis of said first numbers referred to modulus B 
x D; and 

adding means (7) coupled to said correc- 
tion means and to a starting addrdss index 
register (6) so that the generated address in- 
30 dices are based on the starting address index. 

2. Apparatus as claimed in claim 1, wherein the 
generating means comprise: 

a multiplier (5) operable to multiply to- 
3fl gether the value of D and the delta index c; 

and 

an adder (3) operable to generate the said 
first numbers by successive cumulative addi- 
tions of the output value provided by the muiti- 
40 pilar. 

3* Apparatus as claimed In claim 1, wherein the 
generating means comprise: 

an adder (3) operable to output numbers 
45 generated by successive cumulative additions 
of the delta index c; and 

a multiplier (5) operable to multiply the 
numbers output by the adder by D, to gen- 
erate the said first numbers. 

so 

4. Apparatus as claimed in claim 1, 2 or 3, 
wherein the correction means (10, 10*) are 
operable to replace the said first numbers gen- 
erated by said generating means by numbers 
66 represented by R in the equation 

X * R(mod(BxD)) 
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where x is a number generated by the gen- 
erating means, the numbers represented by R 
being supplied to the adding means (7) to 
have the starting address added thereto to 
provide said address indices. 



8. A method of performing 
tor access to a constant 
of a memory device, the 
a starting address and a 
memory device having t 



5* Apparatus as claimed in claim 4, wherein the 
correction means comprises first and second 
dividers, each of which is operable to carry out 
the operation:- 10 

x «■ y = Q and R 

where x, y, Q and R are integers, and Q is a 
quotient and R Is a remainder, and 75 

the first divider is arranged to receive at its 
x terminal the said first numbers generated by 
the generating means, and to receive at its y 
terminal a value BxD, 

the second divider is arranged to receive 20 
at rta x terminal the said first numbers gen- 
erated by the generating means, and to re- 
ceive at its y terminal a value BxDxc, 

and the output vaJue at the Q terminal of 
the second divider is multiplied together with 25 
the value BxD and then added to the output 
at the R terminal of the first divider, 

6. Apparatus as claimed In claim 3, wherein the 
correction means (10') are operable to replace 30 
the numbers output from the adder (3) by 
numbers represented by R' In the equation;- 

X- = R'(mod B) 

35 

where X* Is a number output from the adder 
(3). 

7, Apparatus as claimed in claim 6, wherein the 
correction means comprises first and second *o 
dividers, each of which is operable to carry out 

the operation:- 



a constant stride vec- 
strlde vector address 
vector address having 
distance or stride, the 
i plurality of memory 
banks numbered with respective bank indices, 
and Individual addresses of the memory de- 
vice being numbered with respective address 
indices interleaved through the memory banks, 
the method comprising generating successive 
address indices of the constant stride vector 
address, by:- 

(a) generating a sequence of first numbers 
of which the first one Is *ero and which 
differ from each another by a value com- ■ 
puted in accordance to an equation 

c x D = 1 (mod B) 

where B and D are positive integers 
coprlme to each other, B being the number 
of banks of the memory device and O being 
the said distance or stride of the vector 
address, or B being the number of banks 
and D the stride after division be the great- 
est common factor of the number of banks 
and the stride, and c being a positive in- 
teger called a delta index; 

(b) effecting correction such that said ad- 
dress indices are generated on the basis of 
said first numbers referred to modulus B x 
D; and 

(c) adding a value based on the starting 
address index so that the generated ad- 
dress indices are based on the starting ad- 
dress index. 

9. A method as claimed In claim 8, wherein said 
first numbers are the numbers l n for each value 
of n, where 

l n a n(c x D) 



x + y = Q and R 

45 

where x, y, Q and R are integers, and Q Is a 
quotient and R is a remainder, and 

the first divider Is arranged to receive at its 
x terminal the numbers output from the adder 
(3), and to receive at Its y terminal a value B, so 

the second divider Is arranged to receive 
at Its x terminal the numbers output from the 
adder (3), and to receive at its y terminal a 
value BxD, 

and the output value at the Q terminal of ee 
the second divider is multiplied together with 
the value B and then added to the output at 
the R terminal of the first divider. 



and n Is an integer, 

and wherein 
the first numbers l A are replaced by second 
numbers R rt having a relation with l n expressed 
by 

l<i ■ Rn (mod (B x c x D)) 

and wherein 
the starting address Is added to Rn. 

10- A method as claimed in claim 8, wherein said 
first numbers are the numbers ]'„ for each 
value of n, where 
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I'n = nc 

and n is an integer, 

and wherein 
the first numbers r n are replaced by second 
numbers R f n having a relation with P„ ex- 
pressed by 

r n = R' ft (mod <B) 

end wherein 
R' n is multiplied by D, 
and 

the starting address is added to the value R',, x 
D so obtained. 

PatentansprtJche 

1. Vorrichtung. die betrelbbar 1st urn elnen Kon- 
stantschritt-Vektor2ugrlff auf elne Konstant-' 
schritt- Vektoradresse einer Speicheivorrichtung 
durchzufUhren, wobei die Vektoradresse eine 
Startadresse und einen Abstand Oder Schritt 
aufweist, die Speicheivorrichtung eine Mehr- 
zahl von mit entsprechenden Bankindizes nu- 
merierten Speicherb&nken aufweist und einzei* 
ne Adressen der Speichervorrichtung mit ent- 
sprechenden AdreBindizes numeriert sind, die 
durch die Speicherblnke hindurch verschach- 
telt sind, wobei die Vonichtung einen AdreBge- 
nerator umfaBt, der betreibbar ist, urn aufeinan* 
derfolgende AdreBindizes der Konstantschritt- 
Vektoradresse zu erzeugen, umfassend: 

Erzeugungsmittel (1, 2, 2', 3, 4, 5) zur 
Erzeugung einer 8equen2 von ersten Zahlen, 
von denen die erste Null ist und weiche sich 
voneinander durch elnen Wert unterschelden, 
der gemSB einer Gleichung 

c x D » 1 (mod B) 

berechnet ist, wobei B und D positive, zueinan- 
der teilerfremde ganze Zahlen sind, B die B3n- 
keanzahl der Speichervorrichtung ist und D der 
Abstand oder Schritt der Vektoradresse ist 
oder B die BSnkeanzahl und D der Schritt 
nach Division durch den grBflten gemeinsamen 
Faktor der BSnkeanzahl und des Schritts und c 
eine Deltaindex genannte positive ganze Zahl 
1st 

Korrekturmlttei (10), die derart betreibbar 
sind, daB die AdreBindizes mit Bezug auf Mo- 
dulus B x D auf der Grundlage der ersten 
Zahlen erzeugt werden; und 

Addffionsmhtel (7), das an die Korrektur- 
mittel und an ein StartadreBindaxregister (6) so 
angekoppeh ist, daB die erzeugten AdreBindi- 
zes auf dem StartadreBindex basieren. 



2 070 B1 24 

2. Vorrichtung nach Anspruch 1, bet der die Er- 
zeugungsmittel umfassen: 

elnen Multlpllzlerer (5), der betreibbar ist, 
urn den Wert von D und den Deltaindex c 
5 mKeinander zu multipiizieren; und 

elnen Addierer (3), der betreibbar ist urn 
die ersten Zahlen durch aufeinanderfolgende 
kumulative Additionen des durch den Murtipli- 
zierer bereitgestellten Ausgangswerts zu er- 
io zeugen. 

3l Vorrichtung nach Anspruch 1, bei der die Er- 
zeugungsmittel umfassen: 

einen Addierer (3), der betreibbar Ist, urn 
75 Zahlen aus2ugeben, die durch aufelnanderfoh 
gende kumulative Additionen des Deltaindex c 
erzeugt werden; und 

elnen Multiplizierer (5), der betreibbar ist, 
urn die Zahlen, die vom Addierer ausgegeben 
20 warden, mh D zu multipiizieren, urn die ersten 
Zahlen zu erzeugen. 

4, Vorrichtung nach Anspruch 1, 2 Oder 3, bei der 
die Korrekturmittel (10, 10') betreibbar sind, 

25 urn die durch die Erzeugungsmittel erzeugten 
ersten Zahlen durch Zahlen zu ersetzen, die 
durch R in der Gleichung 

X = R (mod(B x D)) 

30 

dargestellt sind, worin X eine durch die Erzeu- 
gungsmittel erzeugte Zahi ist, wobe) die durch 
R dargestellten Zahlen dem Additlonsmlttel (7) 
zugefOhrt werden, damrt die Startadresse dazu 
35 addlert wird, urn die AdreBindizes bereltzustel- 
len. 

5. Vorrichtung nach Anspruch 4, bei der das Kor- 
rekturmlttei einen ersten und zwehen Dividierer 

40 umfaBt, von denen jeder betreibbar ist urn die 
Operation:- 

x * y = Q und R 

43 auszufuhren, wobei x, y, Q und R ganze Zah- 

- ten sind und Q ein Quotient ist und R ein Rest 
ist und 

der erste Dividierer angeordnet ist, um an 
seinem x-AnschluB die durch die Erzeugungs- 
59 mrttel erzeugten ersten Zahlen zu empfangen 
und an seinem y-Anschlufl elnen Wert B x D 
zu empfangen, 

der zwefte Dividierer angeordnet 1st um an 
seinem x-AnschluB die durch die Erzeugungs- 
65 mittel erzeugten ersten Zahlen zu empfangen 
und an seinem y-AnschluB einen Wert B x D x 
c zu empfangen. 

und der Ausgangswert am Q-Anschlufi des 
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zwelten Dividierers unit dem Wert B x D multl- 
pliziert wird und dann zur AusgangsgroBe am 
R-AnschluB des ersten Dividierers addlert wird. 

B. Vorrichtung nach Anspruch 3, bei der die Kor- 
rekturrnittel (10') betrelbbar sind, um die von 
dem Addierer (3) ausgegebenen Zahlen durch 
Zahlen zu ersetzen, die durch FV in der Glei- 
chung> 

X- = R' (mod B) 

dargestelh sind, wobei X* eine Zahten-Aus- 
gangsgrBBe des Addierers (3) ist 

7. Vorrichtung nach Anspruch 6, bel der das Kor- 
rekturmitlel einen ersten und zwelten Dividierer 
umfaflt. von denen jeder betrelbbar ist. um die 
Operation:- 

x t y o Q und R 

auszufUhren. wobel x. y, Q und R ganze Zah- 
len sind und Q eln Quotient ist und R ein Rest 
ist und 

der erste Dividterer angeordnet ist, um an 
selnem x-AnschluB die vom Addierer (3) aus- 
gegebenen Zahlen zu empfangen und an sei- 
nem y-AnschluB einen Wert B zu empfangen. 

der zweite Dividierer angeordnet ist, um an 
selnem x-AnschluB die vom Addierer (3) aus- 
gegebenen Zahlen zu empfangen und an sel- 
nem y-AnschluB einen Wert B x D zu empfan- 
gen, 

und der Ausgangswert am Q-AnschluB des 
zweiten Dividierers mit dem Wert B murtipJi- 
ziert wird und dann zur AusgangsgrSBe am R- 
AnschluB des ersten Dividierers addlert wird. 

a Verfahren zur DurchfOhrung elnes Konstant- 
schritt-Vekiorzugriffs auf elne Konstantschritt- 
Vektoradresse einer SpeJchervorrfchtung, wo- 
bei die Vektoradresse eine Startadresse und 
einen Abstand Oder Schrttt aufweist, die Spei- 
chervorrlchtung eine Mehrzahl von mh entspre- 
chenden Bankindi2es numerierten Speicher- 
binken aufweist und elnzelne Adressen der 
Spelchervorrichtung mit entsprechenden 
AdreBindizes numeriert sind, die durch die 
SpeicherbSnke hindurch verschachtelt sind, 
wobei das Verfahren die Erzeugung von auf- 
einanderfoigenden AdreBindizes der Konstarrt- 
schritt-Vekioradresse umfaflt, durch:- 

(a) Erzeugen einer Sequenz von ersten Zah- 
len, von denen die erste Null ist und welche 
sich voneinander durch einen Wert unter- 
scheiden, der gem38 einer Gleichung 



10 



15 



20 



26 



30 



35 



46 



SO 



C x D = 1 (mod B) 

berechnet ist, wobei B und D positive, zu- 
einander teilerfremde ganze Zahlen sind, B 
die Bankeanzahl der Speichervorrichturtg ist 
und D der Abstand Oder Schritt der Vektor- 
adresse Ist Oder B die Bankeanzahl und D 
der Schritt nach Division durch den grSBten 
gemeinsamen Faktor der B3nkeenzahl und 
des Schritts und c eine Deltaindex genannte 
positive ganze Zahl ist; 

(b) Bewirken einer Konrektur derart, daB die 
AdreBindizes mit Bezug auf Modulus B x D 
auf der Grundlage der ersten Zahlen er- 
zeugt werden; und 

(c) Addieren elnes Werts, der auf dem 
StartadreBindex baslert, so daB die erzeug- 
ten AdreBindizes auf dem StartadreBindex 
basieren. 

9. Verfahren nach Anspruch 8. bei dem die er- 
sten Zahlen die Zahlen l n fur jeden Wert von n 
sind. wobel 

l„ a n(c x D) 

und n eine ganze Zahl ist, 
und worm 

die ersten Zahlen l n durch zweite Zahlen R n 
ersetzt werden, die eine Bezlehung zu l n auf- 
weisen, die durch 

l n = R„ (mod (B x c X D)) 

ausgedrOckt wird, 

und worin 
die Startadresse zu H n addiert wird. 

10. Verfahren nach Anspruch 8, bei dem die er- 
sten Zahlen die Zahlen )' n far jeden Wert von n 
sind, wobel 

l'n= nc 

und n eine ganze Zahl ist, 
und worin 

die ersten Zahlen l'„ durch zweite Zahlen R' n 
ersetzt werden, die eine Beziehung zu J' n auf- 
weisen, die durch 

l' n = R' n (mod (B)) 

ausgedrOckt wird, 

und worin 
R'n mit D multipliziert wird, 

und 

die Startadresse zu dem so erhaKenen Wert 
R'n x D addiert wird. 
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Revindications 

1, Appareil pouvant fonctionner pour nSaJiser un 
accfes vectoriel a pas constant sur une adresse 
vectorielle a pas constant d'un disposrtif de e 
memoire, I'adresse vectorielle presentant une 
adresse de debut et une distance ou pas, le 
disposittf de memoire comportant une pluraJlte 
de batteries de memolres numSrotSes a Palde 
d'index de batterle respectifs et dee adresses io 
indMduelles du dlspositif de memoire e'tant 
numerotees & Palde d'lndex d'adresse respec- 
tifs emrelac^s sur les batteries de memoires, 
Tappareil incluant un genSrateur d'adresses 
pouvant fonctionner pour ggnerer des index ts 
d'adresse successifs de Padresse vectorielle h 
pas constant, comprenant : 

un moyen de generation (1, 2, 2\ 3, 4, 5) 
pour g,£n£rer une sequence de premiers nom- 
bres dont le premier vaut zero et qui different 20 
les uns des autres d'une valeur caJcutee 
cortforrnement a une equation : 

cxD ■ 1 (mod B) 

26 

ou B et D sent des entiers positifs en 
congruence mutuelie, 8 $tant le nombre de 
batteries du dlspositif de memoire et D e'tant 
ladlte distance ou (edit pas de I'adresse vecto- 
rielle ou B 6tant le nombre de batteries et D so 
etant !e pas apres division par le plus grand 
commun denominates du nombre de batteries 
et du pas et c 6tant un entier positif appele* 
Index delta ; 

un moyen de correction (10) fonctionnant ss 
de telle sorte que lesdits index d'adresse 
soient g£n£r£s sur la base desdrts premiers 
nombres rapports au modulo B x D ; et 

un moyen d'addition (7) couple audit 
moyen de correction et a un registre d'index 4q 
d'adresse de debut (6) de telle sorte que les 
index d'adresse generes soient bases sur Pin- 
dex d'adresse de debut 

2. Appareil selon la revendlcatlon 1, dans tequel 46 
le moyen de generation comprend : 

un multiplier (5) qui fonctionne pour mul- 
tiplier ensemble la valeur de D et I'index delta 
c ;et 

un additionneur (3) qui fonctionne pour g£- so 
n4rer lesdits premiers nombres au moyen 
d'additions cumulatives successives de la va- 
leur de sortie produite par le mutoplieur. 

3. Appareil selon la revendication 1, dans lequel 66 
le moyen de generation comprend : 

un additionneur (3) qui fonctionne pour 
emettre en sortie des nombres genres au 



moyen d'additions cumulatives successives de 
Pindex delta c ; et 

un multiplier (5) qui fonctionne pour mul- 
tiplier les nombres amis en sortie par i'addi- 
tionneur par D afin de generer lesdits premiers 
nombres, 

4. Appareil selon la revendication 1 , 2 ou 3, dans 
lequel le moyen de correction (10. 10') peut 
fonctionner pour remplacer lesdits premiers 
nombres genres par led'rt moyen de genera- 
tion par les nombres repre'sentes par R dans 
liquation : 

X - R (mod(B x D)) 

ou X est un nombre genere par le moyen de 
generation, les nombres represents par R 
etant appliques au moyen d'addition (!) pour 
obtenir I'adresse de d6but qui leur est ajout^e 
pour produlre lesdits index d'adresse. 

5. Appareil selon la revendication 4, dans lequel 
le moyen de correction comprend des premier 
et second d'rviseurs dont chacun peut fonction- 
ner pour mettre en oeuvre Popgration : 

x/y = Q et R 

oO x. y, Q et R sonri des entiers, Q est un 
quotient et R est un reste ; et 

le premier diviseur est agence pour rece* 
voir au niveau de sa borne x lesdits premiers 
nombres generis par (e moyen de generation 
et pour recevoir au niveau de S3 borne y une 
valeur B x D ; 

le second diviseur est agence 1 pour rece- 
voir au niveau de sa borne x lesdits premiers 
nombres generes par le moyen de g£n6ration 
et pour recevoir au niveau de sa borne y une 
valeur B x D x c ; et 

la valeur de sortie au niveau de la borne Q 
du second diviseur est multiple ensemble 
avec la valeur B x D puis est addrb'onnee a la 
sortie au niveau de la borne R du premier 
diviseur. 

6. Appareil selon la revendication 3, dans lequel 
le moyen de correction (10') peut fonctionner 
pour remplacer les nombres emis en sortie 
depuis Paddrbonneur (3) par les nombres re- 
presents par R* dans Pequation : 

X = R' (mod B) 

oD x? est un nombre emls en sortie depuis 
I'addhlonneur (3). 
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7. Apparell selon la revindication 6, dans lequel 
le moyen de correction comprend des premier 
et second diviseurs dont chacun peut fonction- 
ner pour mettre en oeuvre reparation ; 

s 

x / y = Q et R 

ou x, y , Q et R sont des entiers, Q est un 
quotient et R est un rest© ; et 

le premier diviseur est agence pour rece- w 
voir au niveau de sa bome x les nombres e*mls 
en sortie depuls 1'addltionneur (3) et pour rece- 
voir au niveau de sa borne y una valeur B ; 

le second dlviseur est agence* pour rece- 
voir au niveau de sa borne x las premiers is 
nombres dmis en sortie depuls I'additionneur 
(3) et pour recevolr au niveau de sa borne y 
una valeur Bx D ; et 

la valeur de sortie au niveau de la borne Q 
du second diviseur est murtipltee ensemble 20 
avec la valeur B puis est addrHonn^e a la 
sortie au niveau de la bome R du premier 
diviseur. 

& Precede de realisation d'un acces vectoriel a 26 
pas constant a una adresse vectorielle a pas 
constant d'un dispositif de memoire, I'adresse 
vectorielle presentant une adresse de debut et 
une distance ou pas, le dispositif de m£molre 
compliant une plurality de batteries de m£- 30 
moires numerates & Palde d'index de batterie 
respectlfs. et des adresses Individuelles du 
dispositif de mSmoIre 6tam numeVotSes a rai- 
ds d'index d'adresse respectifs entrelac^s sur 
les batteries de m^moires, le proceed compre- 35 
nam la gdndration d'index d'adresse successrfs 
de I'adresse vectorielle a pas constant en ; 

(a) g£n£rant une sequence de premiers 
nombres dont le premier vaut ziro et qui 
different les uns des autres d'une valeur 49 
calcutee conf ornament a une Equation : 

c x D = 1 (mod B) 

oO B et D sont des enters posltlfs en 45 
congruence mutuelle, B etant le nombre de 
batteries du dispositif de memoir© et D 
etant ledlte distance ou I edit pas de I'adres- 
se vectorielle ou B Stant le nombre de bat- 
teries et D gtant le pas apres division par le so 
plus grand commun de*nominateur du nom- 
bre de batteries et du pas et c Start un 
entier positif appete index delta ; 

(b) effectuant une correction qui est telle 

que lesdits index d'adresse sont generes 5$ 
sur la base desdits premiers nombres rap* 
portes au modulo B x D ; et 



B1 30 



(c) addffionnarrt une valeur bases sur Tindex 
d'adresse de debut de telle sorte que les 
index d'adresse genets solent base's sur 
l-index d'adresse de ctfbut. 

9. Precede selon la revendlcation 8, dans lequel 
lesdits premiers nombres sont les nombres l n 
pour chaque valeur de n oD 

l„ n n (c x D) 

et n est un entier 
et dans lequel 
les premiers nombres l„ sont remplac^s par 
des seconds nombres R n lies par une relation 
l rt exprimee par : 

l„ = R« (mod (Bxcx D)) 

et dans lequel 
I'adresse de <ti but et addilionnSe a FV 

10. Proc$d$ salon la revendication 8. dans lequel 
lesdits premiers nombres sont les nombres r n 
pour chaque valeur de n oD 

l'„ = no 

et n est un entier 
et dans lequel 
les premiers nombres P n sont remplaces par 
des seconds nombres R' n lies par une relation 
l' n exprimee par : 

!•„ = R'„ (mod B) 

et dans lequel 
R'n est multiplle par D ; et 
I'adresse de debut est addfo'onnSe a la valeur 
R r n x D afnsi obtenue. 
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